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SPECIFICATION 



TO WHOM IT MAY CONCERN: 

BE IT KNOWN, That I, Andrew T. Molitor, a resident of Fridley, Minnesota and 
a citizen of the United States, have invented certain new and useful improvements in: 

Method and Apparatus for Facilitating Peer-To-Peer Application Communication 



of which the following is a specification. 
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Title: Method and Apparatus for Facilitating Peer-To-Peer Application Communication 

BACKGROUND OF THE INVENTION 

1. Field of the Invention 

This invention relates to devices for handling communications between applications 
exchanging data over the Internet. More particularly, this invention relates to a Network Address 
Translation (NAT) device and a system and method using such NAT device for facilitating peer- 
to-peer communication of data over the Internet. 

2. Description of the Prior Art 

As shown in Figure 1, a Network Address Translation (NAT) device 20 of the 
conventional kind is usually placed within an Internet Protocol (IP) network at the border 
between two disparate address realms 50 and 30. One realm 50 may be a private organization's 
internal network 10 and the other realm 30 may be the public global Internet. The problem 
addressed by such a conventional device is that an organization may require a large internal 
network, with many devices on it, each device requiring a unique IP address. In view of the 
currently available address space for unique IP addresses (2 available addresses) and present 
address allocation patterns, this organization may be unable to have allocated to it a sufficient 
number of official IP addresses, by the authorities that assign such addresses. Therefore, the 
organization is effectively forced to make up internally valid addresses for its own internal 
network. This will allow the internal network to function correctly; there is no requirement to use 
officially assigned IP addresses in such a context. The difficulty arises when devices or 
applications (programs running on a particular device) in the large internal network need to 
communicate with the Global Internet (by which we mean any IP network, public or private, 
using officially assigned IP addresses). Because the addresses assigned internally by the 
organization either overlap with officially assigned addresses belonging to some other 



2 



organization, or are officially unassigned, the Global Internet cannot use these to send data 
correctly into the organization's internal network. In order to send data to a network-attached 
device, for example, the sending application must have an address for the target application, and 
the network receiving the data itself must know how to locate the target application. These 
operations work only if all applications involved are in agreement regarding what IP addresses 
belong to what devices and applications. 

One solution is for the organization to have allocated to it some set of official IP 
addresses. These are unique addresses. Any application on the Global Internet sending data to 
these addresses may rely on that data arriving at the entrance to the organization's internal 
network. That is, the Global Internet infrastructure will correctly deliver data to the organization, 
\ t and then (as is the normal case with IP) rely on the organization to locate the right endpoint 
application inside the organization for final delivery. 

^ The organization could then assign each of the official IP addresses it has been 

s _ allocated to an individual application for an indefinite period, allowing a lucky few applications 

Internet access. A better solution, allowing wider access, is to use a device that can, in effect, 
^ assign the officially allocated IP addresses dynamically to whichever applications need access to 

Q the Global Internet at any given time. Addresses are recovered from applications no longer using 
them, and made available for re-assignment. This sharing system works very well and is, in the 
simplest form, exactly what a conventional Network Address Translator (NAT) usually does. 
(See RFC 2663 IP Network Address Translator (NAT) Terminology and Considerations, 
published by the Internet Engineering Task Force (IETF). This is the basic IETF document 
describing the operation and issues surrounding NAT devices.) 

Often, an organization will be assigned some very small number of official IP 
addresses. Perhaps as few as 3 1, or 255 such addresses may be given to an organization. For an 
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organization with thousands of applications on its internal network, a naive NAT, able only to 
assign official IP addresses, may not be enough. If only 31 of, say, 5000 applications (each of 
which might correspond to an individual employee) can be using the Global Internet at once, the 
problem may not be considered fully solved. 

In order to effectively expand the useful size of the officially allocated address pool, 
the organization's NAT will usually have the ability to use the same official address for multiple 
internal applications. Data arriving for a specific official IP address, say, X, may be further 
distinguished by belonging to one of several data streams, say A, B and C. The NAT may have 
assigned address X, stream A to a specific data stream for one application, while address A, 
streams B and C belong to two different, other applications. 

y The stream identifiers are called port numbers. A stream of data in an IP network is 

uniquely identified by the so-called "5-tuple" which consists of 5 separate numeric quantities: 

if ^ 

^ 1) Source IP address 

1 3 2) Destination IP address 

f * 3 ) S ource Port Number 

C 3 4) Destination Port Number 

5) Transport Protocol 

Every data item (packet) in an IP network has these 5 numeric identifiers in it. The 
two IP addresses (items 1 and 2 above) identify, more or less, the source and destination 
applications. The protocol identifies which of the mechanisms for ensuring reliable transport of 
data are being used. For present purposes the protocol is ignored, because it is not something a 
NAT does much with. The source and destination ports (items 3 and 4 above) identify which 
application within the network sent and is to receive, respectively, this packet. 
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A conventional Network Address Translator (e.g., a Private Internet Exchange (PIX), 
made by Cisco Systems, Inc. of San Jose, CA) as viewed by this document operates by altering 
these five numeric identifiers within a packet. As noted above, a NAT device resides at the 
boundary between two address realms, usually, but not always, the Global Internet and an 
organization's private network, where these two networks have incompatible IP addressing 
schemes. A NAT device uses intelligent re-writing of the four source/destination elements within 
each packet flowing through it, to present to each of the two networks a false but compatible view 
of the other network's IP addressing scheme. Each NAT must have a set of rules defining the 
internal address-external address pairing it will use for address translation. A useful NAT must 
build these pairings to allow internal applications to make effective use of available external 
"'i addresses, which will be limited if the external realm requires official IP addresses. 

Y* A conventional NAT device associated with an internal network supports, essentially, 

H two concurrent modes of operation. The first allows data transactions from applications on the 

u internal network outwards to the Global Internet (for example, a corporate user accessing a web 
H page). This is an Internal Client to External Server access. The second allows applications on the 
H Global Internet to access specific services on specific devices on the internal network (for 

it example, a customer accessing an oiganization's web site). This is External Client to Internal 

Server access. The way in which the conventional NAT device builds the address pairing that 

allows the first and second type of access are somewhat different. 

A conventional NAT device implements the first mode as follows: when the initial 
packet of a data transaction arrives on the NAT device outbound, the NAT device examines the 
source address and port (which identify the internal device and the application that originated the 
packet). The NAT then chooses from its pool of available official addresses and ports an 
externally-valid IP address and port to use in place of the internally-valid source address and port 
in the packet. The mapping from the internally-valid source address and port to the externally- 
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valid source address and port is maintained somehow within the NAT, for example, in a table 
defining the correspondence rule. Finally, the NAT modifies the internally-valid source address 
and port fields in the outbound packet, and sends it on. When an inbound reply packet, 
responding to the initial packet, turns up at the NAT from the outside, the destination address and 
port in the reply packet will match the externally-valid source address and port (because in a 
reply, naturally, the sender address and the recipient address change places, exactly as with, say, a 
postal letter). The NAT uses this incoming externally-valid source address and port to locate the 
internally-valid source address and port from the initial, outbound packet. The NAT then uses the 
located, internally valid source address and port to replace the destination address and port in this 
incoming reply packet. Now the incoming reply packet has the correct internally-valid destination 
address and port for delivery to the device and application which sent the initial outbound packet. 

A conventional NAT device implements the second mode using fixed internal- 
external address correspondence configuration information, defined by the person administrating 
the NAT. For this mode, the initial packet will be incoming, arriving at the NAT from the outside, 
with some destination information containing an IP address among those officially allocated, 
because these externally-valid addresses are the only IP addresses the Global Internet can use to 
deliver packets to the target organization with the NAT. The NAT at the target organization 
consults its configuration information to determine which (fixed) internally-valid destination IP 
address and port it should use to replace the externally valid destination address and port 
contained in the incoming packet. In effect, if an application (say, a web server) is present at the 
target organization on internal device A (a non-official, but internally-valid IP address), expecting 
packets on port X, the NAT might be configured to recognize that packets addressed to IP address 
M (officially assigned and externally-valid), port Y should be re-addressed to the internally-valid 
address, device A/port X. Another application at the target organization might be running on 
another internal device, externally identified as device B, at port Z, and the NAT might use an 
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internal-external address pairing for this application using the same internal address A and some 
other port, again according to some fixed, pre-defined configuration data. 

The difficulty is that the first mode only allows Internal Clients to send data to (and 
thereafter receive data from) External Servers, while the second only allows External Clients to 
send data to (and thereafter receive replies from) a small set of Internal Servers at fixed IP 
addresses and ports, pre-defined in the NAT associated with the Internal Servers. Transactions in 
which an External Client connects to a just-created Internal Server at a just-allocated port number 
are not supported. 

A variety of prior art references discuss NAT devices and variations on their basic 
address translation functions: 

U.S. Patent 6055236, titled "Method And System For Locating Network Services 
With Distributed Network Address Translation," covers methods for, in effect, advertising a 
service securely. US Patent 6055236 is silent on the symmetrical issue of providing addresses for 
Client-side information, focusing entirely on advertising externally useful addresses for servers 
and saying nothing regarding external addresses to be used by clients. 

U.S. Patent 5793763, titled "Security System For Network Address Translation 
Systems" is a patent on a NAT device of sorts, except that it only translates IP addresses and it is 
concerned with security considerations. There is nothing taught on the subject of using port 
numbers to expand the "logical" address space available. 

SOCKS. SOCKS is an Internet Engineering Task Force (IETF) standard, which 
provides a mechanism by which an application can query an application firewall as to an 
externally useful address which it can advertise to a remote client application. SOCKS is this 
application's proxy, which provides services similar to a NAT, but operates quite differently. 



Rather than re-writing the packet contents as it flows through the device, SOCKS (like any 
application proxy) will terminate two communication channels, and logically connect them 
together at a high layer inside itself. For example, a server on the inside of a network might start 
its service, and then make a request to a SOCKS application at the edge of the network. The 
SOCKS application will start a "thin" server on its host, at the network edge, and then inform the 
original server of the address and port at which the "thin" server may be found. The original 
server can communicate this information to the client, which connects to the "thin" server which 
SOCKS is operating. SOCKS will then connect to the original server as a client, and then copy 
data received from the external client to the original server, as well as copying data received from 
the original server back out to the external client. In particular, SOCKS is not a NAT and does not 
operate packet-by-packet, which has certain performance and scaling implications. For more 
information on SOCKS, see http://www.socks.nec.com . 

It is expected that there will be an increase in use of IP networks to send data that 
consists of digitized voice, sound or video ("media" content). What is needed is a method and 
apparatus for network address translation facilitating peer-to-peer data exchange, including media 
transmission, over the Internet and other IP networks. 

SUMMARY OF THE INVENTION 

This invention comprises a network address translation device for facilitating 
communication between a first application in a first address realm and a second application in a 
different address realm. The device uses an address translator for translating an address valid in 
the first address realm into an address valid in the second address realm, based on a translation 
rule and for translating the address valid in the second address realm into the address valid in the 
first realm. It also uses an address manager for establishing a translation rule by associating an 
address valid in the first address realm with an address valid in the second address realm. There 
is a control channel communicating with the address manager for receiving from the first 
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application a request for an address valid in the second address realm to be associated with a 
specified address valid in the first realm and for providing the first application access to the 
address valid in the second address realm to facilitate communication of the address valid in the 
second realm to the second application. 

In one embodiment of the invention the applications are entities connected for IP 
telephony. In another embodiment of the invention the address manager establishes more 
complex translation rules such that an externally valid destination address could be translated into 
an internally valid address of one value or a different value depending on the incoming source 
address. Specific remote addresses, larger sets of remote addresses, or any remote address at all 
could be used as the triggers for the use of special, more complex NAT rules. In a further 
embodiment an application is programmed to control, within specified ranges, the translation 
rules established by the address manager. 

DESCRIPTION OF THE DRAWINGS 

Figure 1 is a block diagram showing a NAT device as used in a prior art network to 
connect an internal network with multiple devices or applications to the Internet. 

Figure 2 is a block diagram showing a NAT device performing address translation 
according to the prior art. 

Figure 3 is a block diagram showing a NAT device according to an embodiment of 
the present invention for facilitating communication between an application in the address realm 
served by the NAT and an application in another address realm. 

DETAILED DESCRIPTION 



I. Peer-to-peer Applications 
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A system using the present invention is useful for, at least, the new class of Internet 
applications that operate in a peer-to-peer (two or more devices located anywhere and 
communicating essentially symmetrically) fashion as opposed to the traditional model in which 
one device is at a well-known location (IP address), and the other may or may not be located at a 
well-known location (IP address). 

The new generation of Internet Applications such as IP Telephony, Instant 
Messaging, and so on, allow users on networks in different address realms to connect directly to 
one another's computers to share data or to collaborate, or just to chat in a continuous, real-time 
interaction. In these protocols, each user's computer will set up an application that might be 
^ termed a micro-server, and then communicate to the other computer, located in a different address 
H realm, an IP address and port at which that micro-server can be reached. (This is the "Just-created 
f! Internal Server" at the "just-allocated port number" which a conventional NAT device does not 
:1 handle). To complete the peer-to-peer connection, each user's computer then launches a client 

u application to connect to the micro-server in the other's address realm. The respective client 

**i applications must then be put in possession of an address at which the micro-server on the other 

wr* in"' 

ft computer in the other's address realm can be reached. Thereafter, two-way communication 

hi between the two client/micro-server pairs can commence, using the NAT to handle the different 

address realms. 

As noted above, Figure 1 shows the context in which a conventional NAT is used. 
The general problem usually to be solved is that of a large internal network 10, existing in a realm 
50 of un-official, or un-assigned, IP addresses, which are unknown to, or will not be correctly 
routed by, the Global Internet. The NAT device 20 is deployed at the interconnect point (or 
points) of the internal network 10 to the Global Internet 30. Using a small pool of officially 
assigned addresses, the NAT 20 creates the illusion, to the Global Internet 30, of a small network 
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of devices using the officially assigned IP addresses, and provides some access to the Global 
Internet 30 to many or all of the devices within the internal network 10. 

Peer-to-peer applications will not work through a current generation NAT device, in 
part because of the limited way an application and its corresponding NAT communicate. 
Normally, a NAT device deals only with the IP address fields of message packets, performing 
address translation according to a limited set of rules. Figure 2 shows the basic address 
translation functions of a conventional NAT 120. Host A 110 is part of an address realm 100 
serviced by conventional NAT 120. Application A 1 121 is running on Host A. It has a 
destination or terminating address that is internally valid and is used to get incoming message 
packets routed to it. Application Al also may have an originating address that is used to identify 
Application A 1 as the source of message packets that Application A 1 originates. As discussed 
above, an IP message packet includes a five part IP header. Thus, an outgoing packet 130 that 
Application A 1 desires to send to Host R 210 in a remote, external address realm, will have the 
following components in its IP header 140: 

1) Source IP address 

2) Destination IP address 

3) Source Port Number 

4) Destination Port Number 

5) Transport Protocol 

This IP header is followed by data 142, which may be media. When Application Al presents 
outgoing message 130 to NAT 120, the NAT 120 must replace any internally valid addresses and 
port numbers with externally valid addresses and port numbers. The NAT 120 may have 
hardware and software 122 that apply its translation rules, stored in any form, such as a 
correspondence table 124. Typically, Application A 1 121 is in possession only of its internally 
valid Source IP address and Source Port Number (its originating address) and the NAT 120 must 
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translate these as inserted in any outgoing message 130 into an externally valid address header 
240 for packet 230 before transmitting them on to Host R 210. If we assume for simplicity that 
Host R is in an address realm 200 that uses official IP addresses, no NAT or address translation is 
needed for it to deliver packet 230 with the externally valid address header 240 to the specified 
destination IP address and port in Host R's address realm 200. 

Host R's reply packet 250 will use externally valid IP addresses in its address header 
260. The NAT 120 will need to translate these externally valid addresses into internally valid IP 
addresses for its address realm 100. Again, the NAT will use hardware and software 122 that 
apply its translation rules, stored in any form, such as a correspondence table 124. The result 
transmitted to Host A from Host R is an internally valid packet 150 with appropriately-translated 
address header 160 that has an internally valid destination address and port, (i.e., the terminating 
address for Application A 1). This permits the internally valid packet 150 with data content 162 to 
reach Application Al . 

The micro-servers for the peer-to-peer communication facilitated by the present 
invention reside, potentially, on any host device within an organization's internal network. These 
micro-servers generally will be assigned a random, available port number by the underlying 
operating system (in an operating system specific way) as the port to use for its service; this will 
be a number currently not in use by any other application on the host device where the micro- 
server runs. Indeed, there is no reason the micro-server needs to reside on the same device as the 
application communicating the micro-server's address, nor is there a need for the micro-server's 
client in the other address realm to reside on the same device as the device to which the micro- 
server's address is to be communicated to set up data exchange. However, if this separation does 
occur, some intra-network communication must occur so that all the applications will know all 
the address and port information they need to know. 



12 

We will refer to the class of applications discussed herein as "peer-to-peer 
applications," which is intended to cover all applications in which two applications communicate 
over a network in an essentially symmetric fashion, where neither application is clearly a server 
or a client in the sense of an application providing a service or receiving a service, respectively; 
rather, both applications perform the same or similar functions on behalf of the other. Note that 
throughout the rest of this document we use the term "client" to mean an application which 
initiates a data transfer session, and the term "server" to mean an application which accepts the 
initiation of a data transfer session from a client. This is convenient terminology, which helps to 
define in which direction the initial data packet passing between two applications passes. This 
initiation step is important for a discussion of NAT behavior. For our purposes, unless otherwise 
stated, the term "client" will mean the application or device sending the initial session packet of a 
data transfer, and "server" will mean the application or device to which that initial packet is 
directed. 

IP Telephony is an important example of a peer-to-peer application. In this example 
each endpoint application acts as a client by initiating a so-called "media" connection to send 
packets containing digitized voice to the other, which receives the packets containing digitized 
voice as a server. The relationship is more or less symmetrical, as digitized voice normally passes 
in both directions. 

In IP telephony, a micro-server on an internal network (say, an IP telephone awaiting 
a stream of digitized voice packets from a remote telephone) will usually need to communicate its 
host device's IP address to a remote client (the other IP telephone, or some other device, such as a 
virtual PBX or other IP telephony gateway acting on behalf of the other telephone). The micro- 
server's internally valid network address won't work for a client on the Global Internet, because 
this address is not an officially assigned IP address. In the event that the micro-server could 
somehow independently discover or compute an official IP address, which it could communicate 
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to the remote client in the initial packet, the conventional NAT would still have no procedures or 
rules for what to do with the first reply packet as sent by the remote client application. That is, 
unless, the NAT itself took part in this discovery or computation of the official IP address in the 
initial packet, the NAT will have no translation rule associating the internal network address and 
any official IP address in an incoming message. 

II , An Improved Peer-to-peer Network Address Translation Device 

The following discussion makes reference to Figure 3 to describe how the present 
invention uses an improved NAT device and method to establish peer-to-peer Internet 
communications. 

1 3 Efficient peer-to-peer application communication between different address realms 

V * *i 

F .t 

\ n requires that the applications (for simplicity, we will confine discussion to two applications 

H exchanging data between them, as opposed to a one^to-many or many-to-many exchange) have 

H access to the official, externally-valid IP address information that will be used in their 

s 2 communication. In the simplest case, a first application needs to have access to (1) the 

externally-valid address information others will use to reach it, so that such first application can 

? » « 

hi communicate that address information to a second application in another address realm, and (2) 

the externally valid address of the second application. In fact, for symmetry and to facilitate 
security and other functions, it is better that each of the first and second applications has two 
addresses: an originating address A 0 , used to identify the device and port of a sending application 
as the source of an outbound message packet, and a separate terminating address, A T , used to 
identify another device and port that will receive inbound message packets. Thus, ideally 
communication is established by each of the first and second applications having and 
communicating two associated official addresses: originating and terminating. In addition, each 
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of the first and second applications has access to the originating and terminating addresses of the 
counterpart with which it wants to have peer-to-peer communication. 

Figure 3 shows a system for facilitating improved communication between two peer 
applications in different address realms. Host A 1 10 and Host B 3 10 are both part of address 
realm 100. Host A has one or more applications running in it. By way of example, Application 
Al 121 and Application A2 122 are shown. Each has an internally valid terminating address and 
internally valid originating address. Host B may also have one or more applications running in it. 
By way of example, Application B 1 321 and Application B2 322 are shown. Host A and Host B 
may be on the same network or otherwise connected so that there is a channel 370 (e.g., 
connection to a common communication network) for communication between Host A and Host 
B. Additional hosts may also be present in this address realm 100 but are not shown. 

Improved NAT 320 serves the address realm 100. Improved NAT 320 has two 
functional sections. One is the address translation section 322, which performs the conventional 
address translation functions as discussed with respect to NAT 120 in Figure 2. The other is the 
address manager section 324. An IP message channel 360 connects Host A 110 to the address 
translation section. This channel 360 is used when an application on Host A or any other host 
served by NAT 320 needs to send out an outgoing message and requires internally valid addresses 
translated into externally valid addresses. The channel 360 is also used when an incoming 
message has arrived with an externally valid address, the NAT 320 has translated the externally 
valid addresses in an incoming message into internally valid addresses and needs to send on the 
message to the appropriate application in address realm 100. 

The address translation section 322 is connected to the "outside" address realms. By 
way of example, Figure 3 shows a Global Internet realm 400 connected to address translation 
section 322. Within address realm 400 is another address realm 200 containing Host R 410 and 
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Host S 510 that may host other applications (Applications Rl, R2, SI and S2 are shown by way 
of example) with which Host A or Host B may communicate. Channel 470 (e.g., a common 
network connection) provides communication between Host R 410 and Host S 5 10. 

A control channel 350 connects Host A 110 (and indirectly Host B 3 10) to the address 
manager section 324. The control channel 350 is used when an application on Host A or any 
other host served by NAT 320 needs to communicate with NAT 320 to request services of the 
address manager 324. The address manager can perform several services for a requesting 
application. First, a requesting application can present an internally-valid address (either an 
originating address or a terminating address), and ask the address manager 324 to provide an 
externally valid address paired with the internally valid address and give the address translation 
section 322 access to this pairing. This can be done so that the address translation section 322 
will use this correspondence as its translation rule for incoming and outgoing message packets. 

Second, an application may cause the address manager 324 to add additional or more 
complex translation rules to those used in the NAT 320, going beyond simple internal/external 
pairings. For example, instead of just performing an unconditional substitution of a 
corresponding internally-valid destination address or port for a specified externally-valid 
destination address or port found in an incoming message, a more complex translation rule can be 
built by the address manager 324 at an application's request. A rule could be formulated so that 
the address translation section 322 checks the incoming source address and/or port and applies a 
different translation rule depending on the content of that field. E.g., externally valid address A E 
in a packet received at NAT 320 is translated into internally valid address An, if a certain source 
address is present in the packet; but no translation is done and the packet is discarded if that 
source address is not present. This may be useful for security. Alternatively, an externally valid 
destination port number P E could be translated into an internally valid port number of one value 
P n or a different value depending on the incoming source address. Specific remote addresses, 
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larger sets of remote addresses, or any remote source address at all could be used as the triggers 
for the use of special NAT rules. 

Third, an application could specify to the address manager 324 required or desired 
characteristics for an externally-valid address requested for association with an internally-valid 
address. This could be useful to let an application specify that the external IP address to result 
from translation must be a particular IP address or within a specified range of IP addresses. Thus, 
with an appropriate request, the application could establish a NAT rule that would require that the 
message packet be directed or forced to a particular external server in the public Global Internet 
that, in turn, would direct the message to a particular private network where a certain type of 
transmission or billing could occur before the packet was forwarded again into a public Global 
Internet. 

It can be seen then that the control channel 350 and the address manager section 324 
represent a flexible facility for providing applications both information that they do not get with a 
conventional NAT and the power to establish certain translation rules for the address translation 
section 322 of the NAT. The address manager 324 can be implemented in hardware or software 
or a combination of both. For example, it may desirable that the address manager 324 have its 
own microprocessor and memory for storing the code that determines what services and functions 
are available in response to control messages from an application. It will further be seen that each 
application that communicates with the address manager 324 requires hardware and/or software 
that permits requests to be made over the control channel 350 and requested information or status 
information returned to the application. 

III. Sample Peer-to-Peer Interchanges Using the Control Channel 

Returning to the above discussion of server and client relationships, the function of 
the control channel 350 and communications between an application and the address manager 
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section 324 and address translation section 322 in several different example situations can be 
explained. Each example is presented in reference to Figure 3 . 

Server Address/Port Allocation and Discovery Example: 

Host A 110 in address realm 100 starts a micro-server, an Application A 1 121 that has 
the purpose of communicating address information to Host R 410, in address realm 200 outside 
of address realm 100, which address information Host R 410 can use to connect to the micro- 
server, Application Al . In order to provide Host R with useful address information, the following 
steps occur: 

1 . Application Al 121 contacts the NAT device 320 over the control channel 350 to 
inform the address manager 324 of the internally valid IP address and port 
Application A 1 is using; 

2. Application Al 121 receives from the address manager 324 in return an 
externally valid IP address and a port number which the NAT device 320 will 
translate to the internally valid terminating address provided by Application Al 
in its request. 

3 . Application A 1 (which we must assume has the ability to address an IP message 
packet to Host R, Application Rl 421) then sends an IP message packet via the 
address translation section 322 of NAT 320. The data portion of the packet 
contains the externally valid IP address and a port number to inform Host R 410, 
Application Rl 421 how to send packets to Application Al . 

4. Application Rl 421 at Host R 410 sends a connection request per the externally 
valid IP address and a port number Application Al gave it, which (being 
correctly addressed to an official IP address) arrives at the NAT 320, where the 



externally valid address is translated to Application Al 's internally valid address 
and port. 

5. NAT 320 sends the reply packet from Application Rl 421on to Application Al 
121 on Host A. 

Client Address/Port Allocation and Discovery Example: 

The external Host R 410 in address realm 200 starts a micro-server, e.g., an 
Application Rl 421. Application Al has the intention of communicating address information to 
Host R, in address realm 200 outside of address realm 100, which address information Host R can 
use to validate an incoming connection from Host A. In order to provide Host R 420 with useful 
address information, the following steps occur: 

1 . Application Rl 42 1 sends a packet to Host A requiring from Host A, Application 
Al 121, information about from which IP address and port the connection from 
Application Al 121 will originate. This originating address information is useful 
for security and may be required by Application Rl for its own purposes, such as 
compliance with a communication protocol. 

2. Application Al 121 on Host A contacts the NAT device 320 over the control 
channel 350 to inform the address manager 324 of the internally valid IP address 
and port Application Al will use to communicate with the micro-server on Host 
R. 

3 . Application Al 121 receives from the address manager 324 in return an 
externally valid IP address and a port number into which the NAT device 320 will 
translate the internally valid originating address provided by Application A 1 in its 
request. 
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4. Application Al 121 (which we must assume has the ability to address an IP 
message packet to Host R, Application Rl) then sends an IP message packet via 
the address translation section 322 of NAT 320. The data portion of the packet 
contains the externally valid IP address and a port number to inform Host R, 
Application Rl 421 from what IP address and port packets from Application Al 
121 will originate. 

5. Application Al 121 then initiates the connection by sending an outgoing packet 
addressed to Host R, Application Rl 421, which packet arrives at the address 
translation section 322 of NAT device 320. 

6. The address translation section 322 of NAT device 320 translates the packet's 
source address and port (which indicate Application A l's internal IP address and 
port) to the externally valid version of these (which was passed to Application A 1 
in step 3 and which Application A 1 sent to Application Rl in step 4). 

7. The address translation section 322 sends the packet on to Host R, Application 
Rl with the source information Application Rl now expects. 

Server Address/Port Allocation and Discovery with Separate Requestor/Server Example: 

In this example. Host A and Host B make use of a communication channel 370 
between them. This permits an application on Host A to act as a proxy for an application on Host 
B. For example, if applications on Host B are IP telephones without much intelligence, then Host 
A could be a virtual PBX with applications that could address a variety of services (e.g., directory 
assistance, telephone number to IP address association) needed by an IP telephone or could be 
some other form of IP telephony gateway. With the use of a proxy, it is evident that there need be 
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no relationship between the addresses and ports actually owned or used by the requesting entity, 
and those addresses and ports called out in the requests to the address manager 324. 

Host B 310 in address realm 100 starts a micro-server, e.g., an Application Bl 321 
that has the purpose of communicating address information to Host R, in address realm 200 
outside of address realm 100, which address information Host R (which will act as the client) can 
use to connect to the micro-server, Application BL In order to provide Host R with useful address 
information, the following steps occur: 

1 . Application Al 121 communicates with Application Bl over channel 370 to 
discover what internally valid address and port can be used to contact Application 
Bl 321. 

2. Application Al 121 needs to contact Application Rl in address realm 200 to 
provide Application Rl externally valid address information for Application Bl . 
Application Al contacts the NAT device 320 over the control channel 350 to 
inform the address manager 324 of the internally valid IP address and port 
Application B 1 is using; 

3 . Application Al 12 1 receives from the address manager 324 in return an 
externally valid IP address and a port number which the NAT device 320 will 
translate to the internally valid terminating address for Application Bl provided 
by Application A 1 in its request. 

4. Application Al 121 (which we must assume has the ability to address an IP 
message packet to Host R, Application Rl 421) then sends an IP message packet 
via the address translation section 322 of NAT 320. The data portion of the 
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packet contains the externally valid IP address and a port number to inform Host 
R, Application Rl 42 1, how to send packets to Application B 1 32 1 . 

5. Application Rl 421 at Host R sends a connection request per the externally valid 
IP address and a port number Application A 1 121 gave it, which (being correctly 
addressed to an official IP address) arrives at the NAT 320, where the externally 
valid address is translated to Application B l's internally valid address and port. 

6. NAT 320 sends the reply from Application Rl on to Application B 1 on Host B. 

Client Address/Port Allocation and Discovery with Client/Servers separated from Negotiating 
Entities Example: 

In this example, Host R 410 and Host S 510 make use of a communication channel 
470 between them. This permits an application on Host R 410 to act as a proxy for an application 
on Host S 510 . For example, if applications on Host S are IP telephones without much 
intelligence, then Host R 410 could be a virtual PBX with applications that could address a 
variety of services (e.g., directory assistance, telephone number to IP address association) needed 
by an IP telephone or could be some other form of IP telephony gateway. 

Host S 510 in address realm 100 starts a micro-server, e.g., an Application SI. 
Application Bl has the intention of communicating address information to Host S 510, in address 
realm 200 outside of address realm 100, which address information Host S 510 can use to 
validate an incoming connection from Host B. In order to provide Host S 5 10 with useful address 
information, the following steps occur: 

1 . Application Rl 42 1 sends a packet to Host A 1 1 0 requiring from Host A, 
Application Al 121 information about from which IP address and port the 
connection with Application Bl 321 will originate. This originating address 
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information is useful for security and may be required by Application SI for its 
own purposes, such as compliance with a communication protocol 

2. Application Al 1 2 1 communicates with Application B 1 32 1 over channel 370 to 
discover what internally valid address and port will be used by Application Bl 
321 to contact Application SI 521. 

3 . Application Al 121 on Host A contacts the NAT device 320 over the control 
channel 350 to inform the address manager 324 of the internally valid IP address 
and port Application Bl will use to communicate with the micro-server on Host 
S510. 

4. Application A 1 121 receives in return from the address manager 324 an 
externally valid IP address and a port number into which the NAT device 320 will 
translate the internally valid originating address provided by Application Al 121 
in its request. 

5 . Application A 1 121 (which we must assume has the ability to address an IP 
message packet to Host R, Application Rl 421) then sends an IP message packet 
via the address translation section 322 of NAT 320. The data portion of the 
packet contains the externally valid IP address and a port number to inform Host 
R ? Application Rl 421 from what IP address and port packets from Application 
Bl 321 will originate. 

6. Application Rl 421 will communicate with Application SI 521 via 
communication channel 470 to communicate to Application SI 521 the IP 
address and port Application B 1 321 will use to communicate to Application SI 
521. 
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7. Application B 1 321 then initiates the connection by sending an outgoing packet 
addressed to Host S, Application SI 521 , which packet arrives at the address 
translation section 322 of NAT device 320. 

8. The address translation section 322 of NAT device 320 translates the packet's 
source address and port (which indicate Application BTs internal IP address and 
port) to the externally valid version of these (which was passed to Application A 1 
121 in step 4 and which Application A 1 sent to Application Rl 421 in step 5. 

9. The address translation section 322 sends the packet via Host R 410 on to Host S, 
Application SI 521 with the source information Application SI now expects. 

'li IV A Voice Communication Application 

[t A. Without NAT 

13 To explain in greater detail the application of the present invention to IP telephony it is 

C3 helpful to explain how a simple phone call using a protocol called SIP might work. SIP is the 

M Session Initiation Protocol, but is a generally accepted shorthand for SIP and all the related 

C3 protocols that work together to allow users to do telephony (and some other things) over data 

networks, like IP. 

In a simple example, there are basically two messages that get sent to establish a phone call. 
(This discussion suppresses certain detail; there may in fact be quite a bit more going on.) The 
two messages we are concerned with are the INVITE message, and the OK response to it. 

Assume that someone, using a SIP telephone designated Phone A wishes to make a telephone 
call to someone else, possibly identified by a telephone number, or some other identifier such as 
an email address. The person making the call would enter the desired target party by typing in the 
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phone number or other identifier. Of course, Phone A doesn't know anything about where the 
target party is, but it does know where a smarter device called a proxy server is. Phone A 
therefore formulates an INVITE message which includes information about who the target is, 
some other information and - significantly - destination information about where Phone A 
expects to receive media packets from the target whenever the target is located, rung, and picks 
up the phone. Phone A will typically supply this information in the form of its own IP address, 
and a port number. Let us imagine that these are 1 . 1 . 1 . 1 , and 1 1 1 1 , respectively. 

The proxy server contacted by Phone A will probably send the INVITE on to other proxy 
server devices, following some network search path, until the target is located. At this point, the 
INVITE message originally formulated by Phone A is delivered to the target, which we will 
designate as Phone B. Phone B will presumably ring for a while, and (with luck) someone will 
pick it up. At this point Phone B replies with an OK message, which includes a variety of 
information, including the destination address at which Phone B expects to receive media. Let's 
imagine this is IP address 2.2.2.2, port number 2222. 

Phone B may begin to send media packets with digitized voice to 1.1.1.1/1111 immediately, 
because it received this information in the INVITE message. When the OK message returns 
(through the proxy servers) to Phone A, that phone may begin to send similar media packets to 
2.2.2.2/2222. Digital audio data is being sent in both directions at this point, and conversation 
presumably ensues. 

B. With NAT 

With a NAT device in the picture, we have three cases to be discussed. In the first case, the 
target phone is eventually located by the proxy servers inside some NAT device. In the second, 
the source phone is located inside some NAT device. In the third case, neither phone is located 
"inside" a NAT device, but the media traffic between them needs to traverse a network located 
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inside a NAT device. In the examples discussed below, all NAT devices are of the kind discuss in 
Figure 3 . 

The various cases may be combined, of course. In general, some proxy server will provide to 
other proxy servers in the network, as well as to the phones involved, the illusion that there are no 
NAT devices. Because this can be done successfully, you can actually have many NAT devices 
working with many proxy servers, each convinced that it is the only NAT, and each convincing 
the rest of the network that, in effect, "there is no NAT here." 

1 . Target Phone is Inside a NAT 

In this case, the target phone, Phone B, which is inside the address realm of a NAT, will have 
no problem sending data to the originating phone, because a NAT generally provides things 
"inside" with the ability to simply send traffic out to anywhere, by addressing it to the outside 
address. The difficulty is in sorting out what to tell the originating phone, because the target 
phone is "inside" a NAT, it cannot be reached from the outside without some help from the NAT. 
The target phone does not use a globally routably IP address; it probably uses a private IP 
address, an address the rest of the world has no idea how to deliver packets to. Only devices on 
the target phone's local network can address data to the target phone's actual IP address with any 
hope of having data delivered to it. 

In this case, a proxy server within the target phone's network must be involved. Of course, it 
will always be involved anyway, because it has responsibility for routing the INVITE to the 
correct phone within the local network, to complete the call. This proxy server will also process 
the OK response from the target phone. Remember that the target phone writes its address and 
port, 2.2.2.2/2222, into this OK message. In this case, 2.2.2.2 is not a useful address for the 
originating phone, because it is private and only internally valid. The proxy server must, 
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therefore, obtain a different, externally valid address, and replace the address (and possibly port) 
contained in the OK message before sending it back toward the originating phone. 

The proxy server will make a request to the NAT device of the target phone, a "Server 
Address/Port Allocation/Discovery" request. The NAT will reply with an address and port, say 
3.3.3.3/3333, by which devices on the other side (the "outside") of the NAT device may reach a 
device at 2.2.2.2/2222 (the target phone). The proxy server re-writes the OK message to indicate 
3.3.3.3/3333 instead of 2.2.2.2/2222, and sends this new OK message off to Phone A. 

Now when Phone B sends a media packet to Phone A it is addressed to 1 . 1 . 1 . 1/1 1 1 1 , and the 
NAT allows this to work just fine - outbound traffic can be simply addressed to the "right", 
H externally valid address. When Phone A sends a media packet to Phone B, however it will send 

E it to 3.3.3.3/3333 - the destination endpoint information it received in the OK message. Assuming 

S I correct configuration, this packet will arrive at the NAT device, which will translate it so that it is 

H now addressed to 2.2.2.2/2222, per the request made by the proxy server, and sent inside the 

L network. The media packet is now correctly addressed, and is within the local network which 

P knows how to deliver this "privately addressed" media packet, so the media packet arrives at 

:5? Phone B, as desired. 

2. Target Phone is Outside the NAT 

This is almost exactly the same as the previous example, except that in this case the proxy 
server near Phone A (which is now the phone "inside" the NAT, and which has a private IP 
address useful only within its local network) must re-write the INVITE message after querying 
the NAT device for an externally valid address. Perhaps the 1.1.1.1/1111 address is re-written 
under the requested NAT rule to 4.4.4.4/4444 (1.1.1.1 is assumed to be a private IP address, while 
4.4.4.4 is not, in this case). 
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A media packet from Phone A proceeds outwards through the NAT device unchanged, while 
a media packet from Phone B, outside the NAT will be addressed to 4.4.4.4/4444, will arrive at 
the NAT device and be translated to 1 . 1 . 1 . 1/1 1 1 1 , and finally delivered to Phone A inside. 

3 . Both Phones Outside - Transit Network has NATs 

In this case we assume that both phones are somewhere "out there", and the network with the 
NAT devices is a transit network - perhaps a long-distance carrier for IP telephones. We assume 
further that this network is taking part in the processing and routing of INVITE and OK 
messages. Perhaps this network provides person-location services, as well as media handling. 

Let us leave Phone A and Phone B at 1 . 1 . 1 . 1/1 1 1 1 and 2.2.2.2/2222 respectively. 

\ [* Assume the INVITE from Phone A arrives at some proxy server in the NAT-equipped transit 

It network under consideration. We may call this the Ingress Proxy Server, because it handles the 

"inbound" INVITE in our example. The Ingress Proxy Server performs the same "Server 
;L Address/Port Discovery" as in the earlier examples, to discover an address that a device inside the 

P transit network could use to reach Phone A. Let us assume that it performs this operation on a 

W specific NAT device, designated NAT A, which is at the egress point from the transit network to 

P Phone A. Say NAT A returns an address/port, which is 10.10.10.10/1010. This is a private 

address, useful within the transit network, which things inside that transit network could use to 
reach Phone A. That is, any message packets within the transit network addressed to 
10.10.10.10/1010 would be routed by the network to NAT A, which would translate the addresses 
to 1 . 1 . 1 . 1/1 1 1 1 . and send them on to Phone A. 

The INVITE message (now indicating that Phone A wished to receive media at 
10.10.10.10/1010) is sent on across the transit network. At some point, another proxy server 
which we will call the Egress Proxy Server because it will handle the INVITE on the way out of 
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the transit network, will receive this INVITE. This Egress Proxy Server will perform yet another 
request, on another NAT device (say, NAT B) well situated to provide traffic to and from Phone 
B, to discover an address by which things "outside" NAT B may reach the endpoint currently 
contained in the INVITE - 10.10.10.10/1010. NAT B should respond with some address, say 
20.20.20.20/2020. The point of this address is that packets sent by things outside (say, for 
example, Phone B) addressed to 20.20.20.20/2020, arriving at NAT B, will be re-addressed, 
specifically, translated to be addressed to 10.10.10.10/1010. Then the transit network will route 
this data (because it's set up to route this way) to NAT A, which will re-address the data again to 
1 . 1 . 1 . 1/1 1 1 1 as indicated in the previous paragraph. 

The INVITE is then sent on to Phone B, which will send media packets to address 
20.20.20.20/2020, per the contents of the INVITE. The media packets will travel to address 
20.20.20.20, which will, assuming correct network configuration, cause it to arrive at NAT B, 
where it will be translated to 10.10.10.10/1010, and thence to NAT A. NAT A will translate it to 
1.1.1.1/1111, and send it on to Phone A. 

Exactly the same set of operations, though resulting in different addresses, will apply to the 
OK coming back from Phone B, but in the opposite direction. First the Egress Proxy Server will 
ask NAT B for an address by which things inside the transit network may reach Phone B (at 
2.2.2.2/2222). Perhaps NAT B will return the address 40.40.40.40/4040. The OK message will be 
re-written by the Egress Proxy Server to indicate this, and be sent on to the Ingress Proxy 
Server. This Proxy Server will ask NAT A for an address by which things outside (say, Phone 
A) may reach address 40.40.40.40/4040. NAT A might return the address 50.50.50.50/5050. The 
OK will be re-written again to indicate this, and be sent on to Phone A, which will then send all 
its media packets to address 50.50.50.50/5050. 
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The upshot is that Phone B sends its media packets to 20.20.20.20/2020, and Phone A will 
send its media packets to 50.50.50. 50/5050, and all the addresses eventually get translated so that 
the media packets arrive at the right place at the end of the day. 

The advantages of doing this are that IP addresses such as 20.20.20.20 and 50.50.50.50 can 
be forced by applications that the ability to control a NAT and selected to be addresses that 
belong to the transit network itself, guaranteeing that the packet from the two phones arrive at 
suitable ingress points to the transit network itself, guaranteeing that the transit network actually 
handles the media data, and furthermore guaranteeing the ingress point for each media stream. 
Without this, there is no way the transit network has a priori control over how the media packets 
get from one of the phones to the other. 

IV. Conclusion and Alternate Embodiments 

It will be readily apparent to those skilled in the art that innumerable variations, 
modification, applications, and extensions of these embodiments and principles can be made 
without departing form the principles and spirit of the invention. Accordingly, it is intended that 
the scope of the invention be only limited as necessitated by the accompanying claims. 
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Claims 



/. A network address translation device for facilitating communication between a first 
application in a first address realm and a second application in a second address realm 
comprising: 

an address translator for translating an address valid in the first address realm into an address 
valid in the second address realm based on a translation rule and for translating the address valid 
in the second address realm into the address valid in the first address realm; 
an address manager for establishing a translation rule by associating an address valid in the first 
address realm with an address valid in the second address realm; and 



a control channel communicating with the address manager for receiving from the first 
application a request for an address valid in the second address realm to be associated with a 



specified address valid in the first address realm and for providing the first application access to 
the address valid in the second address realm to facilitate communication of the address valid in 



the second address realm to the second application. 



2. 



The network address translation device of claim 1 wherein the address requested by the 



first application is a terminating address. 



3. 



The network address translation device of claim 1 wherein the address requested by the 



first application is an originating address. 



4. 



The network address translation device of claim 1 wherein the first address realm is an 



internal network and the second address realm is an external network. 



5. 



The network address translation device of claim 1 wherein the first address realm is 



private network and the second address realm uses global internet addresses. 
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6. The network address translation device of claim 5 wherein the address manager 
establishes a translation rule by associating an address valid in the private network realm with an 
address valid in the global internet address realm. 

7. The network address translation device of claim 1, wherein the address manager controls 
address translation by establishing rules for the translation of address information in an inbound 
message packet to occur or not occur in response to the presence or absence of specified 
originating address information that in the message packet. 

8. The network address translation device of claim 1, wherein the address manager controls 
address translation by establishing rules for the translation of address information in an inbound 
message packet whereby translation occurs under a first rule or under a second rule in response to 
presence or absence of specified originating address information in the message packet. 

9. The network address translation device of claim 1 ? wherein the communication facilitated 
is peer-to-peer application communication. 

10. The network address translation device of claim 1, wherein the address translator 
performs translation with a rule stored in memory accessible by the address translator. 

11. The network address translation device of claim 1 ? wherein the address manager 
establishes a rule stored in memory accessible by the address translator. 

12. The network address translation device of claim 1, wherein at least one translation rule is 
a rule pairing an address in the first address realm with an address in the second address realm. 

13. The network address translation device of claim 1, wherein the address manager 
establishes a translation rule that forces an association with a destination address in a transit 
network. 

14. The network address translation device of claim 1, wherein the address manager 
establishes a translation rule that forces at least a portion of the communication between the first 
application and the second application to pass through a specified network. 
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15. / A method for facilitating communication between a first application in a first address 
realm and a second application in a second address realm comprising: 

providing the first address realm with a network address translation device having an address 
translator for translating an address valid in the first address realm into an address valid in the 
second address realm based on a translation rule and for translating the address valid in the 
second address realm into the address valid in the first address realm; 

providing an address manager in communication with the address translator for establishing a 
translation rule by associating an address valid in the first address realm with an address valid in 
the second address realm; 

providing a control channel communicating with the address manager; and 
receiving at the address manager from the first application a request for an address valid in the 
second address realm to be associated with a specified address valid in the first address realm; 
and 

providing the first application access to the address valid in the second address realm to facilitate 
communication of the address valid in the second address realm to the second application. 

16. The method of claim 1 5 wherein the step of receiving a request for an address valid in the 
second address realm comprises receiving a request by the first application for a terminating 
address. 

17. The method of claim 15 wherein the step of receiving a request for an address valid in the 
second address realm comprises receiving a request by the first application for an originating 
address. 

18. The method of claim 15 wherein the first address realm is an internal network and the 
second address realm is an external network. 

19. The method of claim 15 wherein the first address realm is private network and the second 
address realm uses global internet addresses. 
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20. The method of claim 19 wherein the address manager establishes a translation rule by 
associating an address valid in the private network realm with an address valid in the global 
internet address realm. 

21. The method of claim 15, wherein the address manager controls address translation by 
making the translation of address information in an inbound message packet occur or not occur in 
response to the presence or absence of specified originating address information in the message 
packet. 

22. The method of claim 15, wherein the address manager controls address translation by 
establishing rules for the translation of address information in an inbound message packet 
whereby translation occurs under a first rule or under a second rule in response to the presence or 
absence of specified originating address information in the message packet. 

23. The method of claim 15 wherein the step of receiving a request for an address valid in the 
second address realm is performed twice and the first application requests and receives both a 
terminating address and an originating address and the address manager not only establishes a 
translation rule by associating a terminating address valid in the first address realm with an 
address valid in the second address realm but also makes use of that rule contingent on the 
presence or absence of specified information in the originating address. 

24. The method of claim 15, wherein the communication facilitated is peer-to-peer 
application communication. 

25 . The method device of claim 1 5, wherein the address translator performs translation with a 
rule stored in memory accessible by the address translator. 

26. The method of claim 15, wherein the address manager establishes a rule stored in 
memory accessible by the address translator. 

27. The method of claim 15, wherein at least one translation rule is a rule pairing an address 
in the first address realm with an address in the second address realm. 
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28. The method of claim 15, wherein the address manager establishes a translation rule that 
forces an association with a destination address in a transit network. 

29. The method of claim 15, wherein the address manager establishes a translation rule that 
forces at least a portion of the communication between the first application and the second 
application to pass through a specified network. 



/0. A system for establishing communication between a first application in a first address 
realm and a second application in a second address realm, wherein the first address realm has an 
address translator for translating an address valid in the first address realm into an address valid in 
the second address realm based on a translation rule and for translating the address valid in the 
second address realm into the address valid in the first realm, comprising: 
an address manager for establishing a translation rule by associating an address valid in the first 



address realm with an address valid in the second address realm; 
a control channel communicating with the address manager; and 

software operatively associated with the first application for communicating to the address 
manager a request for an address valid in the second address realm to be associated with a 



specified address valid in the first address realm, for receiving access to the address valid in the 
second address realm, and communicating the address valid in the second address realm to the 
second application. 



31. The system of claim 30 wherein the address requested by the first application is a 
terminating address. 

32. The system of claim 30 wherein the address requested by the first application is an 
originating address. 

33. The system of claim 30 wherein the first address realm is an internal network and the 
second address realm is an external network. 

34. The system of claim 30 wherein the first realm is a private network and the second realm 
uses global internet addresses. 
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35. The system of claim 34 wherein the address manager establishes a translation rule by 
associating an address valid in the private network realm with an address valid in the in the global 
internet address realm. 

36. The system of claim 30, wherein the address manager controls address translation by 
establishing rules for the translation of address information in an inbound message packet to 
occur or not occur in response to the presence or absence of specified originating address 
information in the message packet. 

38. The system of claim 30, wherein the address manager controls address translation by 
establishing rules for the translation of address information in an inbound message packet 
whereby translation occurs under a first rule or under a second rule in response to the presence or 
absence of specified originating address information in the message packet. 

39. The system of claim 30, wherein the communication facilitated is peer-to-peer 
application communication. 

40. The system device of claim 30, wherein the address translator performs translation with a 
rule stored in memory accessible by the address translator. 

41 . The system of claim 30, wherein the address manager establishes a rule stored in memory 
accessible by the address translator. 

42. The system of claim 30, wherein at least one translation rule is a rule pairing an address 
in the first address realm with an address in the second address realm. 

43. The system of claim 30, wherein the address manager establishes a translation rule that 
forces an association with a destination address in a transit network. 

44. The method of claim 30, wherein the address manager establishes a translation rule that 
forces at least a portion of the communication between the first application and the second 
application to pass through a specified network. 
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Method and Apparatus for Facilitating Peer-To-Peer Application Communication 

ABSTRACT OF THE DISCLOSURE 



A system for performing Network Address Translation, which allows applications to request 
information concerning address translations to be performed, so that those applications may send 
useful information to other applications for the purposes of allowing applications to communicate 
through the NAT device in the absence of statically defined rules for specific channels of 
communication. 
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